package com.suanfa.collect;

/**
 * @author jukg
 * @date 2025/01/10 17:14
 * @description
 * 珂珂喜欢吃香蕉。这里有 n 堆香蕉，第 i 堆中有 piles[i] 根香蕉。警卫已经离开了，将在 h 小时后回来。
 *
 * 珂珂可以决定她吃香蕉的速度 k （单位：根/小时）。每个小时，她将会选择一堆香蕉，从中吃掉 k 根。如果这堆香蕉少于 k 根，她将吃掉这堆的所有香蕉，然后这一小时内不会再吃更多的香蕉。
 *
 * 珂珂喜欢慢慢吃，但仍然想在警卫回来前吃掉所有的香蕉。
 *
 * 返回她可以在 h 小时内吃掉所有香蕉的最小速度 k（k 为整数）。
 */
public class KoKoBananas {

    public static void main(String[] args) {
        int[] piles = {3,6,7,11};
        int h = 8;
        System.out.println(minEatingSpeed(piles, h));
    }



    public static int minEatingSpeed(int[] piles, int h) {
        int left = 1;
        int right = 1000000000 + 1;


        while(left < right){
            int mid = (left+right)/2;
            int hour = hours(mid, piles);
            if(hour > h){
                left = mid+1;
            }
            if(hour <= h){
                right = mid;
            }

        }
        return left;
    }


    public static int hours(int speed, int[] piles){

        int hours =0;
        for(int p: piles){
            hours += p%speed ==0? p/speed: p/speed +1;

        }
        return hours;
    }
}
